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A system and 
method of accessing 
services from end 
terminals disposed in an 170 
integrated telecommuni- 
cations network having a 
packet-switched network 
(PSN) portion such as 
for example, a network 
portion using the Internet 
Protocol (IP) and a 
circuit-switched network 
(CSN) portion such as, 
for example, a wireless 
telephony network 
portion. The PSN portion 
is preferably realized 
as a Voice- over-IP 
(VoIP) network having 
a gateway connected 
to the CSN portion. A 
service or application 
node, preferably a 
WIN/lN-based service 
node comprising a Service 
Control Point (SCP), a 
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msse 2^1? iL e " termmal encounters f armed DP > il creates a Se ™ ce Acce *s Stance as part of a service access server and 
passes control thereto, wherein a service proxy sends a request to a service logic environment, preferably provided as the WIN/IN service 
node. Upon executing an appropriate service -logic portion or portions, the service node returns a result to the service access server which' 
in turn, passes it to the call control process. » ^ WUM,; 
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SYSTEM AND METHOD FOR PROVIDING 
ACCESS TO SERVICE NODES FROM ENTITIES DISPOSED IN AN 
INTEGRATED TELECOMMUNICATIONS NETWORK 

PRIORITY STATEMENT UNDER 35 U.S.C §1 19(e) & 37 C.F.R. §1.78 

This nonprovisional application claims priority based upon the following prior U. S. 
provisional patent application entitled: "Enhancing Supplementary Services through the Use 
of Intelligent Network Principles and Accessing Service Nodes from End Terminals," Ser. 
No. 60/1 16,198 (prior Attorney Docket Number 27950-296L, current Attorney Docket 
Number 1 000-0 1 42), filed January 1 5, 1 999, in the names of: Roch Glitho and Christophe 
Gourraud. 

CROSS-REFERENCE TO RELATED APPLICATIONS 

This application discloses subject matter related to the subject matter disclosed in 
the following co-assigned patent application: "System and Method for Providing 
Supplementary Services (SS) in an Integrated Telecommunications Network," filed 

December 1 0, 1 999, Ser. No. (Attorney Docket Number 1 000-0 1 42), in the 

names of: Roch Glitho and Christophe Gourraud. 

BACKGROUND OF THE INVENTION 

Technical Field of the Invention 

The present invention relates to integrated telecommunication systems and, more, 
particularly, to a system and method for providing access to service nodes from entities 
(e.g., endpoints, terminals, gatekeepers, etc.) disposed in an integrated telecommunications 
netw.ork. The exemplary integrated telecommunications network may comprise a packet- 
switched network (PSN) coupled to a circuit-switched network (CSN>. Also, the network 
may comprise a PSN portion only-. * 
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Description of Related Art 

Coupled with the phenomenal growth in popularity of the Internet, there has been 
a tremendous interest in using packet-switched network (PSN) infrastructures (e.g. , those 
based on Internet Protocol (IP) addressing) as a replacement for, or as an adjunct to, the 
existing circuit-switched network (CSN) infrastructures used in today' s telephony. From 
the network operators' perspective, the inherent traffic aggregation in packet-switched 
infrastructures allows for a reduction in the cost of transmission and the infrastructure cost 
per end-user. Ultimately, such cost reductions enable the network operators to pass on the 
concomitant cost savings to the end-users. 

Some of the market drivers that impel the existing Voice-over-IP (VoIP) technology 
are: improvements in the. quality of IP telephony; the Internet phenomenon; emergence of 
standards; cost-effective price-points for advanced services via media-rich call 
management, et cetera. Some of the emerging standards in this area are the well-known 
H.323 protocol, developed by the International Telecommunications Union (ITU), Session 
Initiation Protocol (SIP) or Internet Protocol Device Control (IPDC) by the Internet 
Engineering Task Force (IETF), or Simple/Media Gateway Control Protocol (SGCP or 
MGCP). Using these IP standards, devices such as personal computers can inter-operate 
seamlessly in a vast inter-network, sharing a mixture of audio, video, and data across all 
forms of packet-based networks which may interface with circuit-switched network 
portions. 

As is well-known in the telecommunications industry, services and service 
provisioning are the raison d'etre of a telecommunications network, including VoIP 
networks. Services are typically categorized into (i) "basic services" (i.e., services which 
allow basic call processes such as call establishment and termination) or (ii) "advanced 
services" which are also commonly referred to as Value-Added Services (VAS). It is also 
well-known that advanced services operate as factors for market differentiation and are 
crucial for network operators' (or service providers') success. 

Because of the.integration of PSNs and£SNs, two approaches are available for 
providing Value-Added Services (also known in H.323-based VoIP networks as 
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Supplementary Services) in VoIP networks. The IP-based VAS architecture is based on 
the notion that because telephony call control logically resides within the end terminals of the 
network, service implementation should preferably be localized therein also. This 
architecture makes terminals the primary actors for IP VAS . On the other hand, there exists 
an Intelligent Network (IN) or Wireless Intelligent Network (WIN) service architecture for 
providing VAS in the context of CSNs. The WIN/IN service architecture is network- 
centric, that is, service implementation is done in the network, with centralized service logic 
in a service node (e.g., a Service Control Point or SCP) that is accessed by switching 
entities. Applied to IP telephony, this implies access from such entities as gatekeepers (in 
H.323 networks) or proxy/redirect servers (in SIP networks). 

It should be apparent to those skilled in the art that each of the VAS approaches 
set forth above has its own shortcomings and deficiencies. For instance, in IP-based VAS 
architectures, a significant concern is that the architecture does not address service mobility 
(i.e., end-user can access the services regardless of the terminal/appliance used). Also, 
typically a small number of services are provided in these approaches, which tend to be 
rather simple as well. Further, as the number of services available increases, the issue of 
service interaction becomes more significant because there is no centralized logic for 
resolving contentions or conflicts among the services. 

In the case ofWIN/IN service architectures, a principal drawback is the complexity 
of the CSN itself Also, another significant shortcoming is that network-based service 
architectures do not scale reliably as the number of available services keeps increasing 

As is well known, there have been several VAS solutions, depending upon the 
particular standard used in IP telephony. For example, the H.323 standard comes 
equipped with theH. 450 protocol for Supplementary Services(SS). Similarly, there are 
solutions such as Call Processing Language (CPL) for the SIP-based IP telephony. Also, 
there exist Application Programming Interface (API)-based solutions such as, e.g., Parlay, 
VHE/OSA, etc. ' - 

\* ♦ However, it should be appreciated by those of ordinary skill in the art that several 
shortcomings and? weaknesses exist in the 'state-of-the-art service provisioning schemes in 
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VoIP networks, regardless of whether they are H.323-based, SIP-based, or otherwise. 
For example, none of the solutions is complete or fully satisfactory per se. Service 
invocation is usually not addressed in these solutions. If addressed at all, service invocation 
- capabilities are rather limited and poorly provided. Further, each solution is a "closed" 
5 entity in that it does not permit the integration of other solutions, either existing or yet to 

come. 

Based on the foregoing, it is apparent that there has arisen an acute need for a 
service provisioning architecture for use within the context of the burgeoning VoIP 
technology which overcomes these and other shortcomings and deficiencies of the current 
10 IP- and WIN/IN-based service architectures. The present invention provides such a 

solution. 



SUMMARY OF THE INVENTION 

Accordingly, the present invention advantageously provides a generalized service 
1 5 invocation and realization architecture for use with an integrated telecommunications 

network preferably comprising a PSN portion that is operable with any known IP standard . 
, The service invocation and realization architecture includes one or several IP telephony call 
control modules which integrate the IN-derived Detection Points (DPs) and implement an 
f API which allows services to influence ongoing calls. The call control modules may be 
20 implemented in terminals, H. 323 gatekeepers, SIP entities, in Media Gateway Controllers 

(MGCs), or any node in the network that is capable of effectuating call control. A Service 
Access component or instance — responsible for evaluating service requests and for 
creating appropriate service proxies when a new DP is encountered in call control is 
• provided. Thus, one or several specialized service proxies which actually invoke services 
25 t n:t onbehalf of the Service Access component and mediate between the services and the call 
• ^control, if necessary, are also.included in the service architecture of the present-invention. 
lf In^addition, services — which may be implemented using several technologies, e.g., 
r# IN/A^A\TN/CAMEL Seryice^Cqntrol Points,non T IN-related application servers (e.g., 
P^ r lay;application server), call conti;olrresidentservices (e^g, Java executables), service 
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scripts (e.g., SIP CPL, SIP CGI, etc.), or mobile agents — are implemented as within a 
universally accessible Service Logic Environment or Environments. 

Further, the service proxies and the Service Access component operate in concert 
as a Service Access server to provide access to local services, mobile agent services, or 
remote service nodes in an appropriate Service Logic Environment. A user profile used by 
the various components to invoke the right services at the right time is included in the service 
architecture. This user profile may partly be co-resident with the call control module, or 
reside at a remote location that is retrievable. In addition, the profile may preferably be 
modifiable by various applications, including services implemented as mobile agents. 

In one aspect, the present invention is directed to method of accessing a service 
node, preferably, e.g., a Wireless Intelligent Network (WIN) node, from an end terminal 
disposed in an integrated telecommunications network having a Voice-over-Internet 
Protocol ( VoIP)-based PSN portion and a cellular network portion. An interface module 
is disposed between the service node and the PSN- VoIP portion. The method 
incorporates one or more detection points (DPs) in a call control process provided with the 
end terminal. The DPs are preferably WIN-compliant, and operate to pass control to a 
Service Access instance of the Service Access server when the call control process 
encounters an armed DP of appropriate type. Thereafter, the Service Access server 
determines if one or more services need to be executed. If so, a service request is sent from 
a service proxy of the Service Access server to the service node for service execution. 
Responsive to the service request, a result is received in the Service Access server from the 
service node. Subsequently, the result is forwarded from the Service Access server to the 
call control process of the end terminal. 

In another aspect, the present invention is directed to a service provisioning method 
for invoking a WIN service by an end terminal disposed in an integrated telecommunications 
network having a PSN-VoIP portion and a cellular network portion. The method 
commences by first effectuating a call control process in the end terminal . A determination 
is made in the end terminal if an armed DPassociated with a service request is encountered 
by the call control process. The (ball control process then creates a suitable Service Access 
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instance which evaluates the service request and creates a service proxy accordingly. 
Thereafter, a service node disposed in the cellular network is accessed by the service proxy. 
Subsequently, a service logic portion in the service node is executed to obtain a result which 
is provided to the call control process in the end terminal. 

In yet another aspect, the present invention is directed to an integrated 
telecommunications network wherein IP entities (e.g., end terminals) are capable of 
accessing service nodes disposed therein. The integrated telecommunications network 
includes a PSN portion provided as a VoIP network with one or more end terminals, a 
circuit-switched network (CSN) portion coupled to the PSN portion via a gateway, and 
a service node disposed in the CSN portion. The service node includes service logic 
portions for executing one or more services and is coupled to the PSN portion via an 
interface. A user profile repository, accessed via a user profile retriever, is disposed in the 
PSN portion, which includes a list of triggers for a particular end-terminal-and-subscriber 
combination. A call controller is provided in the end terminal for controlling a call process. 
Also included is a Service Access server that provides access to a service node over a 
suitable interface using a service proxy. When an armed DP is encountered in the call 
process, the call controller creates a Service Access instance as part of the Service Access 
server and passes control thereto depending on the DP' s type. After evaluating the service 
request or requests, an appropriate proxy is created which engages in appropriate 
messaging with the service node for executing a service logic portion thereof 

In yet further embodiments, the above-mentioned aspects of the present invention 
may be practiced with non-IN/WIN services also. 

BRIEF DESCRIPTION OF THE DRAWINGS 

A more complete understanding of the present invention may be had by reference 
^ to the following Detailed Description when taken in conjunction with the accompanying 
t drawings wherein: 

FIG. 1 A depicts a generalized integrated telecommunications network wherein one 
. 9^^\ or .e> < PSN portions^are coupled to an IP-based PSN; . .■ , — 
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FIG. IB depicts a functional block diagram of an exemplary embodiment of an 
integrated telecommunications network having anH.323-based network portion and a 
cellular network portion, wherein the teachings of the present invention are advantageously 
employed; 

5 FIG. 1C depicts a functional block diagram indicating signal flow paths of a 

presently preferred exemplary embodiment of a service provisioning architecture in an 
integrated telecommunications network with an H.323-based VoIP portion; 

FIG. 2 A depicts a high-level functional model of a service provisioning scheme for 
use in an integrated telecommunications network, 
1 0 FIG. 2B depicts a functional block diagram of a VAS-enabled terminal which can 

interact with a user profile retriever in accordance with the teachings of the present 
invention; 

FIG. 2C depicts a flow chart of an exemplary embodiment of a service provisioning 
method for use in an integrated telecommunications network; 
1 5 FIG. 2D depicts a generalized user profile model for use with a service invocation 

and realization architecture provided in accordance with the teachings of the present 
invention; 

FIG. 3 depicts a functional block diagram of a VAS architecture provided in 
accordance with the teachings of the present invention; 
20 FIG. 4 depicts a WIN-compliant Originating Call Control State Machine 

(0_CCSM) for use with an H.323 terminal or a SIP terminal; 

FIG. 5 A depicts a WIN-compliant Terminating Call Control State Machine 
(T_CCSM) for use with an H.323 terminal; 

FIG. 5B depicts a WIN-compliant Terminating Call Control State Machine 
25 (T_CCSM) for use with a SIP terminal; 

FIGS . 6 A and 6B depict message flow diagrams for two exemplary embodiments 
of a call diversion service, respectively, in accordance with the teachings of the present 
invention; 

FIG. 7 depicts a message flow diagram for a hunt group service in accordance with 

BNSDOCID: <WO 0042760A1J_> '* ' 
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the teachings of the present invention; and 

FIGS . 8A-8F depict examples of service invocation and realization in accordance 
with the teachings of the present invention. 

5 DETAILED DESCRIPTION OF EMBODIMENTS 

In the drawings, like or similar elements are designated with identical reference 
numerals throughout the several views, and the various elements depicted are not necessarily 
drawn to scale. Referring now to FIG. 1 A, depicted therein is a generalized integrated 
telecommunications network 1 00 wherein one or more heterogeneous CSN portions are 
3 coupled to an IP telephony network 1 18 (such as, e.g., one based on H.323, SIP, and the 

like) having Value-Added Services in accordance with the teachings of the present 
invention. Each of the CSN portions is provided with a suitable gateway for coupling to the 
IP telephony network portion. For example, a Time Division Multiple Access (TDM A) 
cellular network portion 1 02 is coupled to the IP telephony network portion 1 1 8 via 
> gateway (GW) 114. In a similar manner, GW 1 16 is provided between the Plain Old 

Telephone System (POTS) network portion 1 06 and the IP telephony network portion. 
r . Each of the CSN portions maybe provided with its own service architecture for the 
provisioning of advanced services. For example, the TDMA network portion 1 02, which 
includes one or more mobile terminals, e.g., T 1 24, may be provided with WIN service 
architecture. One or more IP terminals or appliances, e.g., T 1 32 A through T 1 3 2D, are 
disposed directly on the IP telephony network portion 1 1 8. Furthermore, although not 
shown in FIG. 1 , other entities may be provided as part of the IP telephony network portion 
1 1 8 depending upon the specific implementation, for example, gatekeepers and Multipoint 
Cpntrol Units (MCUs) (in ; the case ofH. 3 23 implementation), or proxy servers, redirect 
.servers, registrars and so on (in the case of SIP implementation). Also, one or more legacy 
, telephones or appliances (e.g., T 1 20) are coupled to the IP telephony network portion 1 1 8 
, via ;an IP .adapter; or "gateway" (e.g : , gw 122). : - ' % 

- ^ t , FI ^- IB .depicts a functional block diagram of an exemplary telecommunications 
: netwprk^ AGW 176 is disposed between an H. 323 
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IP network portion 1 96 and a circuit-switched cellular network portion 1 94 of the 
telecommunications network 198. One or more service nodes including at least a Service 
Control Point (SCP), for example, SCP service node 190, optimized for providing 
advanced services in the framework of WIN/IN architecture, is provided as part of the 
infrastructure of the circuit-switched cellular network portion 194. Furthermore, in 
accordance with the teachings of the present invention, a service node converter interface 
(I/F) may be provided between the H. 3 23 network portion 1 96 and the SCP service node 
1 90 such that an H. 3 23 entity, e. g. , a gatekeeper or a terminal, can interrogate the service 
node 1 90 for invoking a subscriber service. Preferably, the converter (not shown in this 
FIG.) is associated with a communication path 1 65, using SS7 or IP, between the H.323 
portion 1 96 and the service node 190. A plurality of "intelligent" H.323 terminals (i.e., 
"service-active" or "service-capable" terminals), e.g., terminal-1 172A (TA) through 
terminal-3 172C (TC), one or more gatekeepers (GKs), e.g., GK-1 174A and GK-2 
1 74B, and an MCU 1 70 are disposed in the H.323 network portion 1 96 in a conventional 
manner. 

In accordance with the teachings of the present invention, a user profile repository 
1 68 is provided as part of the telecommunications network 1 98 for generating triggers to 
the service node 190. The user profile repository 168 is interfaced within the H.323 
network portion via a suitable interface 1 67 such as a HyperText Transfer Protocol (HTTP) 
interface or Lightweight Directory Access Protocol (LDAP) interface. A user profile 
retriever (not explicitly depicted in this FIG.) is included for retrieving user profile 
information to be provided to various call/service components, as will be discussed in 
. greater detail hereinbelow. 

Whether a trigger should be generated to the service node 1 90 depends on the 
. -VAS activated in the network 198, in addition to whether the end-user has an active 
> subscription to it. In order to determine when to suspend and generate trigger's, a call 
control entity (shown in FIG. 2B hereinbelow) is provided with the capability to 
; interface/interact with the user profile retriever to obtain a set of triggers (i.e., end-user 
\prdfiIe)'associ£ted with the end-user. However, it should be appreciated that some 
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constant services, not subject to explicit subscription, or for performance reasons, may give 
rise to some service triggers being stored locally (that is, within an H. 3 23 entity such as a 
terminal, gatekeeper, or a media gateway controller (MGC)). Further, while the user 
profile repository 1 68 is shown in this exemplary embodiment as a separate entity, it should 
be understood that the repository may be co-located with an IP mobility management entity 
or the service node 190 itself. 

In the presently preferred exemplary embodiment of the present invention, the 
service node 190 may be accessed by a host of H. 323 entities such as the terminals, 
gatekeepers, media gateway controllers, etc. For example, FIG. 1 C depicts afunctional 
block diagram with signal flow paths for effectuating service node access in an exemplary 
embodiment of an H.323 VoIP network wherein an IP terminal is provided with the 
capability of accessing a service node, e.g., SCP service node 190. Those of ordinary skill 
in the art should readily appreciate that the signal flow diagram shown in FIG. 1 C is an 
abstraction of the network 1 98 shown in FIG. IB, having only relevant entities shown 
therein. For example, the terminal- 1 1 72 A and terminal-2 1 72B are provided with the signal 
paths 1 73 A and 1 73B, respectively, for interfacing with the user profile repository 1 68. 
r Also, signal paths 187A and 187B are provided between the service node converter 
interface 1 88 and the two terminals, respectively, for accessing the SCP service node 1 90. 

* As can be readily seen, GK- 1 1 74 A is not provided with a signal path to the user profile 
repository 1 68 in this exemplary embodiment. However, it should be understood by those 
skilled in the art that in some implementations, a gatekeeper and/or other IP entities, for 
example, an MGC, may^also be provided with respective signal paths to either the user 
profile repository 168, service node converter interface 188, or both. Furthermore, a 

v proyision may be made for service triggering over a radio interface (e.g. , a General Packet 
Radio System (GPRS) interface). 

; * ; The advantageousfeature of providing access to service nodes from several types 
, of IP entities is enabled by providing a common framework for call control, service access, 
and signaling with respect to such entities. FIG..2A depicts a high-level functional model 
Avhichillustrates the relationship between call/connection control and VAS in accordance 
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with the teachings of the present invention. It should be realized that this functional model 
is independent of the particular standard used for IP telephony and, accordingly, provides 
a universal service invocation and realization architecture for implementing VAS in IP 
telephony networks. Essentially, the service invocation and realization architecture is 
comprised of the following: 

- One or several IP telephony call control modules (e.g., module 202), which 
integrate the IN-derived Detection Points (DPs) and implement an API 
which allows services to influence ongoing calls. The call control modules 
may be implemented in terminals, H.323 gatekeepers, SIP proxies, in 
MGCs, or any node in the network that is capable of effectuating call 
control. 

- A Service Access module (e.g., Service Access server 204) responsible 
for the invocation of VAS, whose functionality is preferably distributed 
between a Service Access component/instance and one or more 
specialized service proxies (shown in FIG. 2B and described hereinbelow) 
which actually invoke services on behalf of the Service Access component 
and mediate between the services and the call control, if necessary. 

- Services (more universally, Service Logic Environment 206) which may be 
implemented using several technologies, e.g., IN/AINAVIN Service 
Control Points, non-IN-related application servers (e.g., Parlay application 
server), call control-resident services (e.g., Java executables), service 
scripts (e.g., SIP CPL, SIP CGI, etc.), or mobile agents. 

- A user profile (described in greater detail hereinbelow with respect to FIG. 
2D) which is used by the various components to invoke the right services 
at the right time. This user profile may partly be co-resident with the call 

" : control module, or reside at a remote location that is retrievable. In 
• ( . ■? addition, theprofile may preferably be modifiable by various applications, 
. ' including services'implemented as mobile 'agents. 

- i • It should be realized that the universal service invocation and realization architecture 
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set forth above advantageously reconciles existing as well as those yet to come IP VAS 
solutions in a coherent and powerful execution and realization environment. 

Functionally, when the call/connection control module 202 is activated pursuant to 
a call being made by an IP entity such as, for example, a calling party, a called party, 
5 gatekeeper, or an MGC, a suitable Call Control State Machine (CCSM) 208 is effectuated 
for providing a mechanism for detecting when the control needs to be passed to the Service 
Access server module 204. As set forth above, the service proxy actually invokes services 
on behalf of the Service Access component therein and operates a mediating interface 
between the services and the call control. Preferably, the functionality of the Service Access 

1 0 server 204 includes determining service events and their order based on the inputs - and 

possibly other conditions, e.g., time - from the call/connection control module 202. The 
Service Access server 204 also determines the location of appropriate service logic (WIN 
and/or non-WIN) for carrying out the service events. In relation thereto, the functionality 
of the service proxies may include the following tasks: 

15 - encapsulate service triggers, etc.; 

- mediate between service client and service server by using appropriate call 
models, protocols, logics, et cetera; and 

- provide event buffering. 

, The service logic environment 206 includes appropriate service logic and operates as a 
20 server for the services provided by the network. It is typically implemented as a service or 

application node in the network and is coupled to the Service Access server 204 via any 
suitable interface such as for example, HTTP, Java RMI, Corba, ASCII/IP, etc. 
Furthermore, as will be explained hereinbelow, some of the services may be local as well. 
, . From a service execution perspective, the three modules inter-operate as follows; 
15 Jhe call/connection control module 202 preferably corresponds to the functionality of 
f WIN/IN Call Control Function (CCF). It implements the CCSM 208, handles call-related 
user interactions and signaling, and performs basic call control processing. Its connection 
to the provisioning of VAS consists of: b.eing able to suspend call processing depending on 
the type of DP or.DPs encountered, creating a Service, Access component as part of the 
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Service Access server and passing control information thereto when call processing is to be 
suspended, and handle VAS answers and/or requests. 

The service proxies of the Service Access server handle interactions with the service 
logic, whether it is local or stored at a remote location. The service proxies may also 
evaluate service criteria, sequence service triggers (also referred to as Feature Interaction 
Management or FIM), generate actual triggers and handles requests from the service logic 
environment 206. 

The service logic environment 206 executes appropriate service logic or logic 
portions ("logics") It may be provided either locally or remotely with respect to the 
call/connection control module 202. In accordance with WIN architecture, the service logic 
environment 206 preferably comprises an SCP node that is accessed remotely. It arbitrates 
and resolves contentions among multiple service logics for execution, if necessary. 

From a VAS perspective, the responsibilities of each functional module are as 
follows: The call/connection control module 202 is preferably provided with the awareness 
as to when services may possibly be executed. Preferably, this knowledge comes with the 
initial retrieval of the end-user profile from the user profile repository 1 68 (depicted in FIG. 
IB). However, in a presently preferred exemplary embodiment of the present invention, 
the call/connection control module 202 may not possess any knowledge with respect to 
whether a service is in fact to be executed, and if so, whether one or more services are to 
be sequenced and what the services are. 

The service proxies are preferably provided as modules which evaluate whether one 
or more services are to be executed or not. In a presently preferred exemplary 
embodiment, these proxies do not know what the services are, although they are aware of 
the specific service invoking mechanisms. The service logic environment module 206 is the 
module that is actually aware of the services to be executed. Preferably, based oh the 
decisions taken by the service logic or logics, it provides a unique answer to the proxies in 

r * the Service- Access server 204. 4 •'■ * 

* - ' " - >~ As stated elsewhere in the patent application/the present invention is directed to 

*■* : providing the capability in IP entities such as terminals (H. 323 or SIP); etc. of accessing 
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service nodes that are preferably WIN/IN-compliant and taking an appropriate action 
based on the result or results obtained therefrom. In other words, the IP entities are 
preferably provided with switching functionality necessary for taking service-related actions 
themselves. As will be described in greater detail hereinbelow, the CCSMs of the IP 
entities are modified in accordance with the teachings of the present invention so as to 
facilitate the foregoing objects. 

Referring now to FIG. 2B, a functional block diagram of a VAS-enabled entity 
(e.g. , an enhanced terminal) is shown therein for illustrating the various aspects of the call 
control and service access process described hereinabove. A user interface 402 is 
provided for interacting with the end-user. It accepts requests from the user (e.g., call 
initiation, call abandon, or call release), obtains necessary information to proceed (e.g., a 
phone number, authentication information, etc.), notifies the end-user about call-related 
events (e.g., another call attempt while a communication session is ongoing), and preferably 
potentiallypromptstheuserforadditionalinformation(e.g., an authorization password) or 
call-related decisions (e.g., how to deal with other call attempts during an ongoing 
communication session). 

v* * A call signaling server 404 is provided for decoding, validating and interpreting call 
signaling messages received from other network entities. Preferably, it may also issue 

» message confirmations, if required. In an H.323/H.450-based VoIP network embodiment, 
the call signaling server 404 receives messages from other H.323 entities such as, for 

*: ' *example,.a terminal, gateway, or a gatekeeper. These messages are defined by the H. 225 .0 
specification, and may include a Supplementary Service (SS) message (in accordance with 

* -H. 450.X Recommendation series) encapsulated therein. Accordingly, in this exemplary 
K : embodiment, the call signaling server 404 is provided with the capability to extract such 
encapsulated. SS messages. * , ' «. , . .« . 

i> v. - /;;^:Fjom the implementation standpoint, the call signaling server 404 may preferably 
be implemented as a dynamic library or as a separate software module. Furthermore, it 

* „t may be combined with a call signaling client 4 14 associated therewith. Preferably, the call 

; ** signaling qlient 4 1 4 translates call control intentions into appropriate : signaling messages sent 
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to other EP telephony entities. Similar to the call signaling server 404, the call signaling client 
414 is preferably operable with multiple IP protocols, e.g., SIP, H.323, et cetera. 

A call manager 406 is provided as a module that treats call setup requirements. In 
some exemplary embodiments, it also treats call release requests if they are not treated 
directly by the call control module 4 1 0. When an end-user initiates or ready to answer a 
call, and when the terminal or appliance is registered with a gatekeeper (in an exemplary 
H.323-based network embodiment), the call manager 406 requests access to the 
gatekeeper (for example, by using the Registration and Access Status (RAS) messages). 
If the access is granted, the call manager 406 creates an Originating or a Terminating call 
control 4 1 0, depending on whether the terminal is the originating or terminating party of the 
call Thereafter, it passes the necessary information to the call control 4 1 0 (e.g. , a calling 
party number, a called party number, etc.). When the call manager 406 is requested to 
complete or abandon a call, it preferably deletes the corresponding call controls also. 

The call control 4 1 0 manages a call - from setup to termination - on behalf of one 
of the call parties (originating or terminating). A call party is characterized by the 
combination of the end-user and the terminal/appliance involved in the call. Accordingly, 
an Originating CCSM (0_CCSM) and a Terminating CCSM (T_CCSM) are provided for 
the call management. Where an H.323-based network is used, the CCSMs are preferably 
both H. 3 23- and WIN-compliant in accordance with the teachings of the present invention. 
In analogous fashion, where a SIP-based network is used, the CC SMs are SIP- and WIN- 
compliant. Preferably, as will be described in greater detail hereinbelow, the CCSMs 
(whether H/323-based or SIP-based) implement a Q.93 1 user-side-based state machine, 
augmented by WIN Detection Points (DPs - points in a call processing sequence where the 
processing may be suspended (because of the particular, type of DP encountered) and 
control is passed to a Service Access component created in the Service Access server 
\ 204); Points in Calls (PICs - points in a call processing sequence where the call processing 

can be resumed ), and. additional states as may <be needed/ . , - - ' 
■ -j v-t 4 Preferably/ the call. control 410 is»started by the call manager 406'. As to its 
termination, itmay stop by itself or based on a decision by the call manager 406. When 
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started, the primary task of the call control 4 1 0 is to obtain a list of the DPs to be armed. 
This list may be stored locally, or may be provided via a user profile retriever. Transitions 
in the CCSM of the call control 410 may result from the following: 

- call signaling received from an IP entity via the call signaling server 404; 

- input from the end-user via the user interface 402; 

- result or request from the Service Access server; 

- result of call control processing which preferably includes the following: 

- treatment of received call signaling; simple tasks may be performed 
locally, more complex ones may be delegated to other modules; 

- interactions with the end-user through the user interface 4Q2, if needed; 
and 

- generation of call signaling. 

As stated elsewhere, when the call control meets an armed DP, it may suspend 
processing based on the nature of the DP. If call processing is not stopped, the call control 
creates a suitable Service Access component and passes relevant information. Also, 
processing resumes (with a possible jump to a specified PIC) when the Service Access 
^server answers, and according to the answer. In a presently preferred exemplary 
embodiment, when the call control 4 1 0 terminates for any reason, it may be required to 
_ notify the call manager 406 before doing so. Furthermore, the interaction between the 
servipes and the call control may be performed either directly (i.e., local services) or via a 
remote service proxy (e.g., WIN, remote services, CPL services). 
. , . Still continuing to referto FIG. 2B ; the VAS functionality of the enhanced terminal 
. associated with a particular VAS implements the necessary logic required to execute the 
Value-Added Service that has been activated at network level and for the end-iiser. In the 
: f ase Q ? an W;450.X-Qompliantarchitecture, the VAS functionality implements H.450.X 
s^fviqe-specific controls and may support one or more roles defined in the-H-450.X 
; Recommendations. It receives H.450 messages addressed to the role it supports in the 
H J^p.X service, and jnay also generate H. 4 5 O.messages to other H.323 entities. In some 
;/ ex ?™$¥% l-^bodimejit § ? the.fiinctionality^ma^ also,impact an on-going call; either by 
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interacting with the call manager 406 (e.g. , to create or delete a call), or possibly with the 
call control 410 itself 

The Service Access server 204 (comprising the Service Access instance and 
service proxies) is provided as the intermediary between the call control 4 1 0 and the service 
logics. Preferably, it makes services and the manner they are accessed or implemented 
transparent to the call control 410. When a service needs to take place, the call control 
may suspend call processing depending on the DP's type and, if the processing is to be 
suspended, it creates a Service Access component as part of the Service Access server and 
passes control to it, together with relevant information about the ongoing call. The Service 
Access server 204 eventually passes the control back to the call control 4 1 0 with relevant 
service-related instructions. In a further exemplary embodiment, these instructions may 
require that the call manager 406 be accessed directly for some reason (e.g. , termination . 
of the call). 

Depending upon the implementation of the IP telephony network and the service 
provisioning therein, the knowledge about the DPs may be gained in a variety of ways. For 
example, a user profile retriever 4 1 9 is provided that retrieves the current user/terminal 
profile from the user profile repository 168, shown inFIG. IB. This profile includes a list 
of active triggers for the user/terminal combination, and therefore specifies the list of DPs 
to be armed. The user profile retriever 419 may retrieve this profile at start-up, or when 
explicitly requested by a client application and may be stored locally (possibly after retrieval 
of part or all of the profile information)/ In addition, the user profile may be directly 
accessed by the components which need them, i.e., call control, Service Access server 
(including the Service Access component, and possibly service proxies in some 
embodiments). * • . ■ 

When the call control 410 passes control to the Service Access server 
depending upon the type of an armed DP that is encountered, the Service Access 
component 4 16 created in connection therewith preferably evaluates if a service or services 
is/are to-be executed, and if so, request for their execution, creates appropriate service 
proxies 41 7 accordingly* Thereafter? tfie'Service Access s'erver 204 answers 4 the call 
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control to resume the call process sequence as it has been doing (i.e., there is no service or 
no service has an immediate impact on the call). Accordingly, as stated hereinabove, the 
call control 4 1 0 may not systematically stop call processing - instead, the nature of the DPs 
encountered determines this condition. If the on-going call is not to be stopped, the call 
control creates a suitable Service Access component and passes call information to it, but 
does not stop or wait for the answer therefrom. 

In the context of service execution, the Service Access component 4 1 6 evaluates 
service requests and certain criteria associated therewith in order to decide if one or more 
triggers are to be generated. Preferably, the Service Access 4 1 6 evaluates these criteria 
in a pre-defined or pre-configured order so as to be able to generate the triggers and 
service requests as defined in the user profile (which may be potentially conflicting) in the 
right order. When a trigger has been generated and answered by a service or application 
node, the Service Access server preferably proceeds as follows: 

- If the service node asks to resume call processing and there is at least one more 
criterion left, the Service Access server evaluates that criterion. 

- If the service node's answer indicates resuming of the call control sequence at 
another PIC, the Service Access server commands the call control 4 1 0 to do so. 

- If there are no additional criteria to be evaluated, the Service Access server 
answers the call control 410 and stops processing 

Preferably, the Service Access server stops its processing by answering the call control to 

* resume the call process sequence as it has been doing (i.e., there is no service or no service 
has an immediate impact on the call). 

* As can be appreciated by those skilled in the art, there may be multiple call controls 
4 1 0 provided at the same time (for example, where the end-user conducts several calls in 

*i,parallel, or the terminal implements a proxy call control), wherein each call control process 
- may require or encounter .its own DP/DPs. Accordingly, a separate Service Access 
y component may be created each time a new armed DP is encountered and, therefore, there 
, .can beseveral Service Access components for a single call. 

Referring now to FIG. 2C, shown therein is a flow chart of an exemplary 
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embodiment of a service provisioning method which captures the essence of the interactions 
of the several modules of the VAS-enabled entity described above, which is capable of 
accessing service/application nodes, including WIN/IN-compliant nodes. As described in 
the foregoing sections, the CC SMs of the VAS-enabled entity are preferably provided with 
one or more DPs, that are preferably WIN/IN-specific. However, because some of the 
WIN/IN DPs are primarily cellular-network-oriented, and therefore not relevant to the 
CCSM of an IP entity, such DPs are not included in the call/connection control module of 
the entity. Also, some DPs are not applicable to terminals (IP or otherwise) and, therefore, 
are not included. 

Accordingly, during a call processing step 210, when an armed DP is detected 
(decision block 212), a subsequent decision is made to verify if the DP is WIN/IN- 
compliant (decision block 214) requiring the creation of a suitable Service Access instance. 
Preferably, the information as to which DPs to be armed for a given end-user and terminal 
combination is accessed directly by the appropriate component i.e., call control, Service 
Access server (possibly including the service proxies). If no armed DP is detected, the call 
processing flow proceeds to subsequent steps which are typically implementation-specific 
(step 220). If the WIN/IN-specific DP is encountered, on the other hand, a new Service 
Access component is created as part of the Service Access server for accessing the 
appropriate service logic or logics in a service/application node (step 216). After the 
execution of the service logics, suitable answer or answers are provided to the Service 
Access server which determines the next step in the call processing sequence. These steps 
are comprehended in steps 218 and 220 of the flow chart. 

Those of ordinary skill in the art should understand upon reference hereto that the 
determination of whether a DP is WIN/IN-compliant, shown in decision block 2 1 4, may 
preferably be avoided by a service provisioning method in some exemplary embodiments. 
.Accordingly, it should be understood that it is not always necessary to check whether the 
DP is WIN/n>J-compliant or not. Regardless, if the DP requires the creation of a Service 
Access instance and possible suspension of the call processing, it will be done accordingly. 
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FIG. 2D depicts a generalized user profile model preferably used in conjunction 
with the universal service invocation and realization architecture depicted hereinabove with 
respect to FIG. 2 A. It should be apparent ,?to those skilled in the art that the 
implementations shown in FIGS. IB and 1C illustrate particular embodiments (H. 323- 
5 based) that are encompassed within the teachings of the generalized user profile model set 
forth herein. 

' As briefly stated in reference to FIGS. 2 A and 2B, a user profile 26 1 (preferably 
utilized as the user profile repository 1 68 in FIGS . 1 B and 1 C or repository 3 1 8 in FIG. 3 
described below) is preferably provided to be interfaced by the various components of the 
10 service invocation and realization architecture in order to invoke the appropriate services 

at the appropriate time.' The user profile 26 1 preferably includes the DPs to be armed for 
both Terminating and Originating CCSMs. For each DP, a sequence is specified: 

^condition of invocation^ => condition based on call data and/or any other 
relevant data (e.g., date, time etc.). May also be TRUE if unconditional invocation. 
15 <service type> => may be WIN, CPL Script, Local Service, Mobile Agent, etc. 

<invocation information^ => any relevant information for the invocation besides 
*■ call data. Forexample, in'the case ofWIN, the trigger type, and the IP address for . 
theSCP. 

> * . A user profile retriever 25 5 (which may preferably be utilized as the profile retriever 

20 . 419 depicted in FIG. 2B) is provided for retrieving a user profile that is related to services. 
. ; preferably; an appropriate interface, e.g., LDAP, HTTP, etc., isused forthis purpose. One 
. * - or more local administrative tools 257 may be used for creating user profile information with 
■ respect to the local services of a subscriber. Services implemented as Mpbile Agents 259 
create appropriate related profile information upon arrival. 
25 Taking FIGS. 2A and 2D together now, the components ofthe service invocation - 

•*f: * • *and realization architecture, may further be described in terms of their universal functionality. 
~k < . Each time an armed DP is encountered, a Service Access (S A) instance (e.g., Service 
v.> \\AQcess component 416 inFIG: 2B) is created with respect thereto depending on theDP's 
: type.l While the SA~modulejhas<no*Knowle<ige ofthe.actuahseryices to be invoked, it. 
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5 



possesses knowledge as to the service invocations and, once created, the SA instance may 
proceed to one or several service invocations or none at all. The SA determines which 
invocations are to be performed, their priority, and how such invocations need to be 
effectuated. Preferably, the user profile provides such knowledge, whereas actual 
invocations are delegated to specialized components. 



Specialized service proxies (e.g., proxies 417 in FIG. 2B) are provided for 
implementing the specific aspects of different service environments. A Local Service Proxy 
may be provided for starting a local service and pass call parameters to it. Similarly, a 
Mobile Agent Proxy mediates between the call control and the mobile agent or mobile 
10 agency. A Local Script Proxy is provided for interpreting a service script (e.g., SIP CPL) 

and reporting its decision or decisions back to the call control. Also, an AS Proxy or WIN 
Proxy is provided for mediating between the call control and the external services. 

As can be seen from the foregoing, services embodying a particular service logic 
environment may be local, remote, or mobile. Accordingly, services may access local or 
15 remote data. Further, a service may exist only for the time to answer the invocation 

associated therewith, or exist for the entire call or a part thereof In addition, a service may 
' * have an immediate impact/deferred impact, or no impact on call control. In some instances, 
a service may not have any relevance with respect to call control at all. Preferably, services 
fc are provided with the capability to interact with the end-user and/or other applications 
20 • ; Referring now to FIG. 3, shown therein is a functional block diagram of a VAS 

' architecture 300 provided in accordance with the teachings of the present invention. The 
* * ; * VAS architecture 300 includes IP telephony entities, e.g., IP TEL entity 302A and IP TEL 
- ■ - entity : 302B, VAS-enabled entities, e.g., IP TEL VAS-enabled entity 304, and VAS- 
specific entities. - r ■ , ' * * :: * ** * c . " 

25 ' The VAS-specific entities preferably encapsulate , or responsible for, the relatively * 

\ ' * ;( volatile part of telephony services which includes the service logics and end-user profiles. 
■* The service" logics and the way they interact together are dete^ 

• environment 206. Services may be added or. removed' on the fly, by the IP telephony 
; r service provider (TSP)| T a*'thi^ or the end-user /They may be 
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stored locally with respect to an IP TEL entity, remotely in a dedicated node (e.g., the 
service logic environment 206), or both. Appropriate logic and data 3 1 6 are included 
within an IP TEL VAS client 3 1 4 of the IP TEL VAS-enabled entity 304 for local service 
implementation. 

The end-user-and-terminal combination profile, which includes the set of services 
activated for the end -user/terminal, may also be stored locally or remotely in a dedicated 
node (e.g. , profile repository 318). In some implementations, both arrangements may co- 
exist- When disposed in a separate node, the profiles are retrieved by using a retrieval 
interface 326 implemented in, for example, HTTP. The access to the service logic 
environment 206 is implemented using a code mobility interface 328 A and a service logic 
access interface 328B. The code mobility interface 3 28 A, typically used for retrieving some 
service logic code or VAS client code from the service logic environment 206, may be 
effectuated using a Java RMI protocol or a Mobility Agent protocol. The service logic 
access interface 328B may be based on the following: 

- IN AP/IP if the service logic environment 206 comprises a legacy IN or WIN 
SCP; 

- Corba or Java RMI if a programmatic interface is needed; or 

- an ASCII/IP interface (e.g., similar to SIP). 

The IP TEL entities are involved in the stable part of telephony services which 
typically consists of the set-up, control, and release of IP telephony calls. For supporting 
the processing and signaling related to this activity, an IP Basic Services (B S) peer 308 is 
provided within the IP TEL entities which, in exemplary embodiments, include IP terminals, 
H 323 gatekeepers;gateways, SIP proxy and/or redirect servers, et cetera. Optionally, an 
IP TEL entity may also take part in the execution of a VAS, that is, it may be able to 

.c generate or process some.requests or notifications related to the service execution. An IP 
TEL VAS peer 306 is provided for effectuating such functionality. As an example, the IP 
TEL VAS peer 306 may be able to re-route a call setup request or may be notified that a 
call diversion has occurred. 

o-: ' . -.: w;- IP,TEL entit%171ay.be VAS-enabled, e.g., entity 304, .when it is also capable of 
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determining which services should take place and when, and of taking the necessary 
measures to execute them using the IP TEL V AS client 3 1 4 that is connected to the volatile 
VAS-specific entities via the interfaces described above. The VAS-enabled entity 304 also 
includes its own VAS peer 3 1 0 and BS peer 3 1 2 for interfacing with other IP TEL entities. 

FIG. 4 depicts a WIN-compliantO_CCSM for use with anH.323 or SIPterminal 
in accordance with the teachings of the present invention. FIG. 5A depicts a WIN- 
compliant TCCSM for use with an H 323 terminal And, FIG. 5B depicts a WIN- 
compliant T_CCSM for use with a SIP terminal. As stated hereinabove, the CCSMs of 
the present invention are preferably based on the Q.93 1 user-side protocol originating and 
terminating state machines. These state machines are then rendered WIN-compliant by 
modifying according to the WIN originating and terminating Basic Call State Models 
(BCSMs), which add DPs and PICs at specific locations with the CCSM. Some WIN 
DPs and PICs are not retained in the terminal CCSMs because they are network-specific 
or not supported in the H.323 standard. 

The 0_CCSM for an IP terminal (H.323 or SIP terminal) is depicted in FIG. 4. 
Each of the states and associated DPs and PICs are described below. 

1 Null (State 502) 
Entry Event: 

Call is abandoned or cleared by the end-user (User Interface) (DP: 
O Abandon or OJDisconnect) 

Call is abandoned or cleared by network or called party (Release 

Complete) (DP: 0_Abandon or 0_Disconnect) 

Called party does not answer the call (Release Complete or Timeout) (DP: 

*0_No_Answer) 

Called party is busy (Release Complete) (DP: 0_Called_Party_Busy) 
1 k Exception handling 

PICrOiNull and 0_Exception 
Functions: '* 
v ' ' *' If the* call "has' been abandoned or cleared by- the end-user, issue a 
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disconnect (Call Release), notify end-user, notify call manager and 
terminate 

If the call had been abandoned or cleared by the called party, notify end- 
user, notify call manager and terminate 

If the called party is busy or does not answer, notify end-user, notify call 
manager and terminate 

If exception handling, process exception, notify end-user, notify call 
manager and terminate 
Exit Event: 

Called party number/address is provided (DP: Collectedlnformation) 
Call is abandoned by end-user (DP: OAandon) 
Call Requested-1 (State 514) 
Entry Event: 

Called party number/address is available (DP: Collectedjlnformation) 

PIC: Analyzedlnformation 

Functions: 

None 

Exit Event: 

Call is abandoned by end-user (DP: O Abandon) 

Automatic transition (DP: Analyzed lnformation) 

Call Requested-2 (State 516) 

Entry Event: 

No event required 

PIC:. Send Call 

Functions: 

Issue a call setup request (SETUP) 
Exit Event: ? 
CalLis.abandoned by end-use^(DP: O Abandon) 
Call setup request has been successfully issued 
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Call Initiated (State 504) 
Entry Event: 

Call setup request has been successfully issued 

PIC: No PIC 

Functions: 

Sets timer and waits for event 
Exit Event: 

Answer indicating that the called party is processing the call request (Call 
Proceeding) 

Answer indicating that the called party user is being alerted (Alerting) (DP : 
0_Term_Seized) 

Answer indicating that the called party user has answered the call 
(Connect) (DP: 0_ Answer) 

Answer indicating that the called party is busy (Call Release) (DP: 
0_Called_Party_Busy) 

Answer indicating that the called party refuses the call (Call Release) (DP: 
OAbandon) 

Answer indicating that the called party requires more setup information 

(Setup Acknowledge) 

Timeout (DP: 0_No_Answer) 

Call is abandoned by end-user (DP: 0_Abandon) 

Overlap Sending (State 506) 

Entry Event: 

Answer indicating that the called party requires more setup information 

(Setup Acknowledge) 

PIC: No PIC 1 

Functions: : * ■ 

Acquire necessary information (preferably via interaction with end-user) 
and send it (Information) 4 : *' * * 
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Exit Event: 

Answer indicating that the called party is processing the call request (Call 
Proceeding) 

Answer indicating that the called party user is being alerted (Alerting) (DP: 
5 O Term Seized) 

Answer indicating that the called party user has answered the call 
(Connect) (DP: 0_Answer) 

Answer indicating that the called party is busy (Call Release) (DP: 
*\ : (^Called^PartyJBusy) 
1 0 Answer indicating that the called party refuses the call (Call Release) (DP: 

0_Abandon) 

Answer indicating that the called party requires more setup information 
(Setup Acknowledge) 

Call is abandoned by end-user (DP: 0_Abandon) 
15 End-user requests a feature (DP: O Mid Call) 

v . * . Timeout (DP: 0_No_. Answer) 

6. Outgoing Call Proceeding (State 508) 
\ K S * (j.. < Entry Event: * ... 

Answer indicating that the called party is processing the call request (Call 
20 : - 1". J?--. I' ; * Proceeding) < . \ 

Functions: 

Notify the end-user that the setup request has been answered 
Set timer and- wait for- event .*'•'' ' 

Exit Event: • • — . ; .a*.Y.O 

25 Answer indicating that the called party user is being alerted (Alerting) (DP: 

1 * ' v j * r^'* O^Term Seized) \p , vr;. v» tyi* 

Answer indicating that thGtcalled party usenhas answered the call 

(Connect) (DP: 0_Answer) >,✓..- K O IV 

Answer indicating that the called party »is busy^(Call Release) (DP: 
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OJ3alled_Party_Busy) 

Answer indicating that the called party refuses the call (Call Release) (DP: 
0_Abandon) 

Timeout (DP: 0_No_ Answer) 

Call is abandoned by end-user (DP: 0_Abandon) 

End-user requests a feature (OMidCall) 

Call Delivered (State 510) 

Entry Event: 

Answer indicating that the called party user is being alerted (Alerting) (DP: 
0_Term_S eized) 
PIC: 0_Alerting 
Functions: 

Notify the end-user that the called party is being alerted 
Wait for event • 
Exit Event: 

Answer indicating that the called party user fras answered the call 
(Connect) (DP: Q_Answer) ■ 

Answer indicating that the called party is busy (Call Release) (DP: 
0_CalledJParty_Busy) . . 
Answer indicating that the called party refuses the call (Call Release) (DP : 
0_Abandon) ^ ' v * 

. Call is*abandoned by end-user (DP: 0_Abanddn) 
End-user requests a feature ,f (O Mid_Call) * 
Call Active (State 512) :v. \ \ • « • * 

Entry Event: - / \- ' r i * 

Answer indicating that the called party user' has answered the call 
« (Connect): (DP ; O ± Answer) \ * .*v ' 
PIC: 0_Active (or;> v : : <; ^ K 

•Functions: v ^ ■ ■ :;' ■;: = r. 4, *v 
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Notify session manager (H.245) that the call is active 
Wait for event 
Exit Event: 

End-user requests a feature (DP: 0_Mid_Call) 
5 End-user clears the call (DP: 0_Disconnect) 

Receives disconnect message from network or called party (Call Release) 
(DP: O Disconnect) 
FIG. 5 A depicts an H.323 terminal's T_CCSM in particular detail. Each of the 
states shown therein and associated DPs and PICs are described below. 
10 1 Null (State 602) 

Entry Event: 

Call is abandoned or cleared by calling party or network (Call Release) 
(DP: T_Abandon or TJDisconnect) 

Calais abandoned or cleared by end-user (User Interface) (DP: 
1 5 T_Abandon or ^Disconnect) 

End-user does not answer the call (User Interaction Timeout) (DP: 
T_No_ Answer) 

End-user is busy (communication appliance is busy or end-user says so) 
(DP: T_Busy) 
20 Exception handling 

PIC: T_Null and T Exception 
Functions: 

If call is abandoned or cleared by calling party or network, notify end-user, 
- , ^notify call manager, and terminate 
25 If the call has been abandoned or cleared by the end-user, issue a 

, ;r * disconnect (Call Release),, notify -end-user, notify call manager and 
\ ; terminate . 

If end-user does not answer the call; issue disconnection request (Call 
Release), notify call manager and terminate ; ^ 
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If exception handling, process exception, notify end-user, notify call 
manager and terminate 
Exit Event: 

An indication of incoming call has been received (Setup) (DP: 
Facility_Selected_and_Available) 
Call Present (State 604) 
Entry Event: 

An indication of incoming call has been received (Setup) 

PIC: Present_Call 

Functions: 

In case no more information is required, issue a corresponding indication 
(Setup Acknowledge) 

Otherwise, unless the end-user has decided otherwise, issue an indication 
that the setup request has been received (Call Proceeding) 
If the end-user has explicitly stated to do so, alert the end-user and issue 
and altering indication (Alerting) 

If the end-user has explicitly stated to do so, directly accept the call by 
issuing a corresponding indication (Connect) 

If the end-user has explicitly stated to do so, directly reject the setup by 
issuing a corresponding indication (Call Release) 
Exit Event: 

A call proceeding indication has been issued (DP: 
Facility_Selected_and_Available) 

An alerting indication has been issued (DP: Call_ Accepted) 

A connect indication has been issued (DP: T_Answer) 

A call* release indication has been issued (DP: T_No_Answer) 

A call release indication has been received (DP: T_Abandon) 

Call Proceeding (State 606) > ■ 

Entry Event: 
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A call proceeding indication has been issued 

PIC: Present_Call 

Functions: 

Present the call to the end-user and set a short timer 
If the end-user cannot be contacted, issue a busy indication (Call Release) 
Otherwise, if the end-user answers the call before the timeout, issue an 
indication that the call is accepted (Connect) 

Otherwise, issue an indication that the end-user is being alerted (Alerting) 
Exit Event: 

A call release indication has been issued (DP: TBusy) 

An indication that the end-user is being alerted has been issued (DP: 

Call_Accepted) 

An indication .that the call is answered has been issued (DP: 
Call_Answered) ? 
A call release indication has been received (DP: T_Abandon) 
4 Overlap Receiving (State 608) 

4 Entry EvenJ: 

A setup acknowledge indication has been issued 
An Information message has been received 



Functions: . r: * 

Wait for an ^Information message 
Analyze the information , 

If still not enough, issue another Setup Acknowledge indication 
In enough information has been received, present the call to the end-user 
If the end-user cannot be contacted, issue a busy indication (Call Release) . 
Otherwise, issue and indication that the end 7 user is being alerted (Alerting) 
^.Exit Eyeivt:^,^ , r - # , ; y, 

. An Information message has been received : > t r# \ 



20 



PIC: No PIC 
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A call release indication has been issued (DP: T_Busy) 

An indication that the end-user is being alerted has been issued (DP: 

Call_Accepted) 

An indication that the call is answered has been issued (DP: 
Call_Answered) 

A call release indication has been received (DP: T_Abandon) 
Call Received (State 610) 
Entry Event: 

An indication that the end-user is being alerted has been issued (DP: 

Call_Accepted) 

PIC: T_Alerting 

Functions: 

Set a timer and wait for a response from the end-user 

If the end-user answers the call, issue a corresponding indication (Connect) 

If the end-user refuses the call, issue a corresponding location (Call 

Release) 

After timeout, issue an indication that the end-user does not answer (Call 

Release) 

Exit Event: 

A call release has been issued (DP: T^N6_Answer) 
A call release has been received (DP: T Abandon) 
A connect indication has been issued (DP: T_Answer) 
Call Active (State 612) ■ *' 

Entry Event: • 
A connect indication has been issued - " ■ 
-PIG: T£ActiVe * . 
Functions: 

Notify session manager (H.245) that the call is active 
Wait for event * * *• ' ' 
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Exit Event: 

End-user requests a feature (DP: T_Mid_Call) 
End-user clears the call (DP: TJDisconnect) 

Receives the disconnect, message from network or called party (Call 
Release) (DP: T_Disconnect) 
FIG, 5B depicts a SIP terminal's TCCSM in particular detail It should be 
realized that the SIP terminal's TCCSM is substantially similar to that of the H.323 
terminal described in greater detail above. Accordingly, only the salient differences 
therebetween are set forth below. . ...... 

Essentially, a new state, state 613, is added in the TCCSM of a SIP terminal, 
r 7 Confirmation Awaited (State 613) 

■ * . . Entry Event: r , , 

. - A connect indication has been. issued . .. . — i 

• # . . PIC: None, .. ■. 

, - i Functions: , 

Notify session manager that a confirmation of the call setup is awaited 
A.*.? f r • Wait for event > . . • %- « ; 

- • ; -L.. * Exit Event: * , ' > * 

• t* Cpnfirmati on pfthe ( call setup has been received from the calling party (DP. 
T\Mid_Call) r t , v . y . , v : V." 

\l<* , r '' l End-user clears Jjhexall (DP: T_Disconnect) 

it / V. * : ^ Receives, the'discpnnect, message from network^pr called party* (Call 
, j 4 . —Release) (DP f : T_Disconnect) ; ' • * . ^ ■ • ' *■ ' v./ 

,/l t c * ■ j 1 ? ad #tiqn, il shQul^lalsp be noted that the DPs and PICs associated with the Call 
.{^^^ state, which r is now entered from the Confirmation Awaited state, are is 

appropriately modified. ,A|sp. .nq specific entry event, is requiredvfpr this state: K . 
\ v'ji-, • ; >.fIGS . 6A,arid 6B^ 
v ofiacalidi version, service, respectiyely,;in accordance wijth the teachings of the present 
^ invention. While it iswelL-kno^^ several "flavors" 



WO 00/42760 



-33- 

of call diversion (SS-DIV flavors, for example, Call Forward Unconditional (SS-CFU), 
Call Forward Busy (SS-CFB), and Call Forward No Reply (SS-CFNR)), there is no 
provision for a time-dependent Call Forward service. FIGS. 6 A and 6B illustrate how the 
existing H. 450 services may be enhanced or extended by using the teachings of the present 
invention. 

Referring in particular to FIG. 6A, a message flow diagram of an exemplary 
embodiment of a time-dependent Call Forward service is shown therein. When terminal- 1 
1 72 A (TA) issues a Call Setup request 1 102, terminal-2 172B (TB) responds by a Call 
Proceeding message 1104, indicating that TB will subsequently answer the request. 
Thereafter, TB ' s T_CCSM encounters an armed DP (Facility_Selected_and_AvaiIabIe) 
and generates a corresponding trigger 1 1 06 to the SCP 1 90. Pursuant to the DP, the call 
control is passed to the SCP 1 90 which provides an appropriate Result 1 1 08. The SCP 
1 90 is aware that a Call Forward service dependent on date and time has been set up for 
the subscriber/TB combination and that the call should be diverted to terminal-3 1 72C 
(TC). The Result 1 108 from the SCP 190 contains the appropriate instruction for the call 
diversion. ' - 

Responsive to the Result 1 108 from the SCP 190, TB issues towards T A 1 72 A an 
H.225.0 Facility message 1 1 10, including an encapsulated H.450.3 Call Re-Routing Invoke 
r request. T A 1 72 A accepts the request by issuing an acknowledgment message (Facility) 
1112 and releases the call by sending a Release Complete message 1 1 14 to TB 172B. 
Thereafter, TA 172 A issues a Call Setup message 1 1 16 to TC 172C, with an 
'■ H.450.3 field indicating that the call has been re-routed from TB 172B. TC 172C directly 
informs TA that the subscriber is being alerted by issuing an Alerting message 1 1 18. Once 
* the subscriber -answers the call, a Connect message 1 1-20 is sent from TC to TA. 

The message flow diagram depicted in FIG. 6B illustrates a variation ohtheiime- 
dependent Call Forward service described above. It can be readily seen that the messages 
;are essentially similar and, : accordingly, only the salient features are set forth below. 

Once . the * T-CCSM - of— TB I7-2B i encounters the *afmed~ 'DP 
(Facility jSelectedr and ^Available),- the call control is passed to the SCP 190 which is 
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aware that the a Call Forward service dependent on date and time has been activated for 
the subscriber/terminal-2. If, for some reason, the call should not be diverted at the selected 
date/time, TB is instructed to resume normal call processing, by sending an appropriate 
Result 1208 thereto. Thereafter, TB instructs TA that the subscriber is being alerted 
(Alerting 1210) and that the call is established (via a Connect message 1212). 

FIG. 7 depicts a message flow diagram for an exemplary embodiment of a hunt 
group service provided in accordance with the teachings of the present invention. When the 
end-user, TA 1 72 A, requests fora Call Setup, providing as number the identification of a 
Virtual Private Network (VPN) group, the O JXSM of TA 1 72A stops upon 
encountering armed Collected_Information and Analyzed_Information DPs and a trigger 
is provided to the SCP;-190. Responsive thereto, the SCP 190 determines that a hunt 
group service is to be executed. That is, a call setup must be attempted with a list of the 
terminating parties, in a pre-defined order, until one of them eventually answers the call. In 
one embodiment, the SCP 1 90 may simply provide the list of numbers to TA 1 72 A and 
stop, provided TA 1 72 A is VAS-enabled to handle such a list and execute the associated 
logic. In an alternative embodiment, the SCP 1 90 may instruct the terminal step-by-step 
. 4 as. to what needs to be done. The message flow diagram in FIG. 7 contemplates this 

alternative scheme. • ■ ' - 

A «« . ' -When the control is passed to the SCP via trigger 1 302 on account of the armed 
DP, the SCP 1 90 instructs TA 1 72 A (via Result 1 3 04) to set up a call with TB 1 72B, and 
dynamically arms the following DPs; 0_No_Answer, 0_Called_Party_Busy, and 
0_Answer. Thereafter, TA 1 72B sends a call setup request 1 306 to TB 1 72B. A Call 
Proceeding message 1308, is issued to TA 172 A, indicating that TB will subsequently 
c answer the request. TB alerts the end-user (Alerting 13 10), but nobody answers the call. 
, * Asa consequence, TB issues a Call Release Complete message 13 12 indicating that there 
is no answer to the call setup attempt by TA 1 72 A. The 0_CCSM of TA encounters the 
QJSTo^ Answer DP and issues a corresponding event 1 3 1 4 to the SCP 1 90. The SCP 1 90 
then proceeds to the next number in the hunt group list, re-requests (via result 1316) the 
. terminal (T A) to attempta.call setup withTC terminal, and dynamically arms the same DPs 
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as set forth above with respect to the TB call setup. 

TA 1 72 A sends a Call Setup 1 3 1 8 to TC 1 72C which returns a Release Complete 
message 1320, indicating that there is no answer. Once again, the 0_CCSM of TA 
encounters the 0_No_Answer DP and issues a corresponding event 1 322 to the SCP 1 90. 
The SCP takes the next number in the hunt group list and proceeds in the same manner as 
described hereinbefore. In this illustration, terminal TD 1 72D of the list answers the call and 
provides a Connect message 1 3 3 0 to T A. Thereafter, the 0_CCSM ofT A encounters the 
O Answer DP and issues a corresponding notification 1 332 to the SCP 1 90 to terminate 
its service logic. 

Referring now to FIGS. 8 A - 8F, depicted therein are several examples of service 
invocation and realization in accordance with the teachings of the present invention. An 
Originating CCSM, such as one discussed in detail hereinabove with respect to FIG. 4, with 
appropriate DPs is exemplified in these exemplary embodiments. Self-explanatory 
scenarios involving local access, mobile agent access, external SCP access, etc. are 

illustrated. * 
■ * - Based upon the foregoing, it should be readily appreciated by those skilled in the 
art that the present invention provides an advantageous solution for accessing service nodes 
from end terminals disposed in an EP network by combining the service architectures from 
the IP and WIN/IN realms into a hybrid approach. Because in the present invention the 
terminals are allowed to access the service logics in a remote location, the limitation of 
reduced number of services available within a terminal has been overcome. Further, 
because the service logics can resolve conflicts and contentions among services and their 
execution, service interaction issues that are prevalent in the IP-based service architectures 
have been resolved. On the other hand, the scalability issues common to the network- 
centric WIN/IN* approach have been eliminated on account of the integration*of the IP 
service architecture. * f . * * ;; ' • * ' * * 

In addition, deficiencies in the current technologies with respect to service mobility 
are also overcome. Because the IP terminal is in a client-server relationship with the service 
node server, the mobility of the terminal is no longer a constraint on accessing the service 
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node server, which can be via INAP or IS-41 over SS7," or in some instances, via Java, 
Corba, etc. Moreover, service mobility is assured because if any intelligent appliance 
capable of accessing the Internet/WWW and download a piece of code, which essentially 
is a client's behavioral image expected by the service node server, the appliance can be 
used for accessing the services. Accordingly, a plethora of communication 
appliances/devices may be used in accordance herewith: Information appliances, 
personal/laptop/palmtop computers, Personal Digital Assistants, smart phones, 
TDMA/CDMA/GSM mobile phones, et cetera. 

Moreover, by utilizing the teachings of the present invention, the WIN/IN service 
logic base that is already installed and market-tested may continue to be re-used even as 
VoIP network architectures come into existence. Those of ordinary skill in the art should 
realize that there exist tremendous incentives, economic as well as infrastructure-based, for 
network operators to re-use the expensive legacy SCP nodes as they migrate towards 
integrating the cellular infrastructures with IP-based PSNs. Also, because the logic 
switching is provided within the terminal, services can be dynamically altered or allocated. 
* For example, in the current network-centric Call Forward-Unconditional (CFU) service, 
, v all calls are forwarded toa C-number whether or not the subscriber wishes to manually 
, override the call forwarding. With the terminal logic provided in accordance with the 
teachings of the present invention, the terminal can interrogate the subscriber for the actual 
call forwarding. Additionally, since some services may be made resident within the terminal 
itself,, individualized service provisioning is possible A . . A 

. .The advantages of providing IP-based VAS in accordance with the universal 
service invocation and realization architecture provided in the present invention may thus 
,cpnveniently e be summarized as below: ■:- 

■V h y ~ v permits flexible addition and/or removal of services; 
* - " r ' .. * integrates various service implementations, ranging from "one size fits all" 
/ to extremely customized services;- . .„ * 
: . - + .j t permits the^ reuse of existing IN/WIN service nodes, 
- ' — v.SCPs and Application Seryersmaydeal with complex service interaction 
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issues and support universal access; 

- applicable to various networks (e.g., SIP, H.323) and their VAS solutions 
(e.g., SIP CPL/CGI, H.450, IN-like, etc.). 

In particular, further advantages are evident when implemented in IP terminals: 

- makes use of terminal capabilities and relieves network nodes from V AS- 
related tasks; 

- implementation is simple and "lightweight"; 

- no constraint on network nodes to support standard call models and access 
to services (e.g., INAP, CAP, ANSI-41, etc.); 

- supports universal access to VAS; * 

- favors interaction with end-user and other local applications (e.g., Web 
browser, etc.). 

' Although the VAS architecture of the present invention has been exemplified with 
particular reference to a H.323-based IP network, it should be understood that other IP 
network implementations such as, for example, SIP-based networks, may also be used for 

- practicing the teachings contained herein. In the case of a SIP-based network, DP- 
' dependent- service triggering may be- performed from SIP terminals, SIP proxies or 
'gateways, SIP redirects (collectively, SIP entities), wherein the SIP entities are provided 
. with the CCSMs appropriately modified in accordance herewith. The call 'control 

functionality described hereinabove with respect to H 323 implementations is also applicable * 
for a SIP-based implementation and, accordingly, a- 'dual mode" IP terminal that is SIP- 

- as weIlasH.323-compliant,in'additionto WIN/IN, may be provided advantageously within 
* an IP network. " " * ' ■ * r ^ 

Further, it is believed that the operation and construction of the present invention 
will be apparent from the foregoing Detailed Description. » While the method and system 

-shown' and' described have been characterized as being preferred, it should be readily 
understood that various changes and modificati6ns could be made therein without departing 
from the scope of the present'invention as set forth ifi the following claims. For example, 

ralthoughthe teachings of the present invention have been exemplified with a particular SS 
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within the context of the H.450.X Recommendations, it should be understood that other 
SSs under the existing or future H.450.X Recommendations may also be provisioned in 
accordance with the teachings of the present invention. That is, in addition to the Call 
Forward and hunt group services exemplified herein, the teachings hereof may be also 
applied in the context of numerous other services, for example, toll free and credit card 
calling, selective call restriction, click to fax, double phone / free phone, split charging, and 
multimedia applications such as tele-medicine, tele-education, video-on-demand, et cetera. 

Furthermore, while pluralities ofH.323-based terminals have been described in the 
exemplary embodiments of the present invention, any combination of non-H.323 entities 
suckas mobile stations operable with a variety of air interface standards may be provided 
for the purposes of the present invention. The IP-based terminals may take several forms 
r themselves: Personal Digital Assistants, Internet phones, laptop computers, personal 
computers, palmtop computers, pagers, and Information Appliances. In addition, the 
9 . innovative teachings contained herein may also be practiced in a VoIP network coupled to 
a PSTN, wherein the fixed entities can trigger service requests to a service node. 
{ ^Accordingly, it should be realized that these and other numerous variations, substitutions, 
, additions, re-arrangements and modifications are contemplated to be within the ambit of the 
: present invention whose scope is. solely limited by the claims set forth below. 
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WHAT IS CLAIMED IS: 

1 . A method of accessing a service node from an end terminal disposed in an 
integrated telecommunications network having a Voice-over-Internet Protocol (VoIP) 
network portion and a cellular network portion, the method comprising the steps of: 

providing an interface module disposed between the service node and the 
VoIP network portion; 

incorporating at least one detection point in a call control process provided 
with the end terminal, wherein the detection point operates to pass control to a service 
access server when the call control process encounters the detection point; 

determining, by the service access server, if a service needs to be executed; 

if so, sending a service request from the service access server to the service 
node for service execution, - 

receiving, in the service access server, a result from the service node 
responsive to the service request; and 

passing the result from the service access server to the call control process. 

2. The method of accessing a service node from an end terminal disposed in 
an integrated telecommunications network as set forth in claim 1, wherein the service 
request is sent from the service access server to the service node over a HyperText Transfer 
Protocol (HTTP) interface. 

3 . The method of accessing a service node from an end terminal disposed in 
an integrated telecommunications network as set forth in claim 1, wherein the service 
request is sent from the service access server to the service node over a Java interface. 

4 . The method of accessing a service node from an end terminal disposed in 
an integrated telecommunications network as set forth in claim 1, wherein the service 
request is sent from the service access server to the service node over a Ccrba interface. 
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5 The method of accessing a service node from an end terminal disposed in 
an integrated telecommunications network as set forth in claim 1, wherein the service 
request is sent from the service access server to the service node over an IP interface. 

6. A service provisioning method for invoking a Wireless Intelligent Network 
(WIN) service by an end terminal disposed in an integrated telecommunications network 
having a packet-switched network (PSN) portion and a cellular network portion, the 
method comprising the steps of: 

effectuating a call control process in the end terminal; 

determining, in the end terminal, if an armed detection point is encountered 
by the call control process; 

if so, creating a service access instance and passing control thereto; 

creating a service proxy associated therewith; 

accessing by the service proxy a service node disposed in the cellular 
network portion; 

• executing a service logic portion in the service node to obtain a result; and 

providing the result to the call control process in the end terminal. 

7 . The service provisioning method as set forth in claim 6, wherein the armed 
detection point is provided by a service access server disposed in the end terminal. 

. . » . 8. . The service provisioning method as set forth in claim 7, wherein the armed 
detection point is acquired by the service access server from a user profile repository 
disppsed in the integrated telecommunications network, the user profile repository including 
,.ja listpf active triggers for the end terminal and a subscriber associated with the end terminal 

„ 9... The service provisioning method as set forth in claim 6, wherein the service 
logic. portion comprises a call diversion service,, *■ 
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1 0. The service provisioning method as set forth in claim 6, wherein the service 
logic portion comprises a hunt group service. 

1 1 . The service provisioning method as set forth in claim 6, wherein the service 
5 logic portion comprises a time-dependent call diversion service. 

1 2. The service provisioning method as set forth in claim 6, wherein the service 
node is accessed using a HyperText Transfer Protocol (HTTP) interface. 

10 13. The service provisioning method as set forth in claim 6, wherein the service 

node is accessed using a Java interface. 

14. The service provisioning method as set forth in claim 6, wherein the service 
* node is accessed using a Corba interface. 

15 

15. The service provisioning method as set forth in claim 6, wherein the service 
node is accessed using an IP interface. 

' 16. An integrated telecommunications network comprising: 

20 a packet-switched network (PSN) portion including one or more end 

terminals, 

' a circuit-switched network (CSN) portion coupled to the PSN portion via 

a gateway; 

•■ - " : a service node disposed in the CSN portion, the service node including 

25 service logic portions for executing one or more services and being coupled to the PSN 
portion via an interface; 

* . ■ * ' : ' * ' ,/ a user profile repository disposed in the PSN portion, the user profile 
repository including a list of triggers 1 for a' particular end-terminal-and-subscriber 
combination; 
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call control means in the end terminal for controlling a call process; 
a service access server in the end terminal that evaluates service requests 
and creates service proxies based thereon, 

wherein the call control means passes control to the service access server 
when an armed detection point based on the list of triggers is encountered in the call process 
such that a service proxy places a request to the service node for executing a service logic 
portion. 

.,-..17. - , The integrated telecommunications network as set forth in claim 1 6, wherein 
the interface comprises a HyperText Transfer Protocol (HTTP) interface. *- 

, . 18. The integrated telecommunications network as set forth in claim 1 6, wherein 
the interface comprises a Java interface. 

*,■«•. -19. The integrated telecommunications network as set forth in claim 1 6, wherein 
the interface comprises a Corba interface. " 

; S t ] : 1 , 20 . : The integrated telecommunications network as set forth in claim 1 6, wherein 
the end terminal is selected from the group consisting of a Personal Digital Assistant, an 
Internet phone, a laptop computer, a personal computer, a palmtop computer, a pager and 

f t : an Information Appliance.^ ■ ..-'■>:' 

21 . The integrated telecommunications network as set forth in* claim 16, 
wherein the PSN portion comprises an H.3 23 network and the end terminal comprises an 

^ .H: 3 23 terminal. « — * ' - 

22. The integrated telecommunications network as set forth in claim 16. 
: wherein the PSN portion comprises a SIP network and the end terminal comprises a SIP 
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23 . An integrated telecommunications network having a generalized service 
invocation and realization architecture, comprising: 

one or more call control modules including a plurality of service-related 
detection points that are Intelligent Network (IN)-compliant; 

a Service Logic Environment implemented to execute a service logic 

.portion; 

a Service Access server coupled to the Service Logic Environment, the 
Service Access server including a Service Access component created when an armed 
detection point is encountered and one or several service proxies operating to invoke a 
service oh behalf of the Service Access component, the service proxies mediating between 
the Service Logic Environment and the call control modules; and 
- - - <>. . a user profile structure specifying the information as to when a service is to 

be invoked for a particular mobile subscriber. 1 ' 1 

% f */2'4. The integrated telecommunications network as set forth in claim 23f 
wherein the service logic portion corresponds to a localservice. ^ • • 

\r x . 25, i: The integrated telecommunications network as set forth in 1 claim 23, 
'* wherein the service logic portion corresponds to a mobile agent-based service. * 

26. The integrated telecommunications network as set forth in claim 23, 
wherein the service logic portion corresponds to a remote service residing in a Service 
Control Point (SCP)noder .v." ' • >. r 

v+ r '- <• -;:vi > • *„•;»"..• .1. ♦ .. ■ > ' v * ..«>-•" 

27. The integrated telecommunications network as set forth in 'claim 23, 
wherein the call control module resides in an H.323 terminal. 

> i :v: t ■ ;*»t ^ ; ■ u « *u p' 

;* i 287 ' * The;integrat6d .tdecdmmuhications'hetwork'as set*fo in 1 claim 23, 
wherein the call control module resides in an H.323 gatekeeper. - ; " • 





WO 00/42760 



PCT/SE99/02490 



-44- 

29. The integrated telecommunications network as set forth in claim 23, 
wherein the call control module resides in a SIP entity. 

30. The integrated telecommunications network as set forth in claim 23, 
wherein the call control module resides in a Media Gateway Controller. 
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